import java.util.Scanner;

/**
 * @author gao
 * @date 2025/6/14 21:59
 */

public class Solution {
    public boolean lemonadeChange(int[] bills) {
        int five = 0, ten = 0;

        for (int i : bills) {
            if (i == 5) {
                five++;
            // 如果账单为10元，则判断是否有5元，如果有则5元数量减1，10元数量加1，如果没有则返回false
            } else if (i == 10) {
                if (five == 0) {
                    return false;
                }
                five--;
                ten++;
            // 如果账单为20元，则判断是否有10元和5元，如果有则10元数量减1，5元数量减1，如果没有则判断是否有3个5元，如果有则5元数量减3，如果没有则返回false
            } else {
                if (five != 0 && ten != 0) {
                    five--;
                    ten--;
                } else if (five >= 3) {
                    five -= 3;
                } else {
                    return false;
                }
            }
        }
        return true;
        // 如果遍历完账单后，没有返回false，则返回true
    }

    public static void main(String[] args) {
        Scanner in = new Scanner(System.in);
        while (in.hasNext()) {
            int n = in.nextInt();
            int[] bills = new int[n];
            for (int i = 0; i < n; i++) {
                bills[i] = in.nextInt();
            }
            Solution solution = new Solution();
            System.out.println(solution.lemonadeChange(bills));
        }
    }
}